package com.sp.fresh_produce.model.dao;

import com.sp.fresh_produce.controller.dto.VO.CategoryVORequest;
import com.sp.fresh_produce.model.pojo.Category;

import java.util.List;
import org.apache.ibatis.annotations.Param;

/**
 * 分类表 Mapper 接口
 * <p>
 * 通过 MyBatis 将 Java 方法映射到 SQL（见 resources/mappers/CategoryMapper.xml）。
 */
public interface CategoryMapper {
    /**
     * 按主键删除
     */
    int deleteByPrimaryKey(Integer id);

    /**
     * 全量插入
     */
    int insert(Category record);

    /**
     * 选择性插入（仅非空字段）
     */
    int insertSelective(Category record);

    /**
     * 按主键查询
     */
    Category selectByPrimaryKey(Integer id);

    /**
     * 选择性按主键更新（仅更新非空字段）
     */
    int updateByPrimaryKeySelective(Category record);

    /**
     * 全量按主键更新
     */
    int updateByPrimaryKey(Category record);

    /**
     * 根据分类名称查询
     */
    Category selectByName(String name);

    /**
     * 统计所有分类数量
     */
    int countCategoryAll();

    /**
     * 分页查询分类
     *
     * @param offset   偏移量
     * @param pageSize 页大小
     */
    List<Category> selectCategoryPage(@Param("offset") int offset, @Param("pageSize") int pageSize);

    /**
     * 根据父级 ID 查询子分类列表
     */
    List<Category> selectCategoryByParentId(int parentId);

    /**
     * 查询所有分类列表
     */
    List<CategoryVORequest> listCategoryForCustomer();
}